//给定一个整数数组 nums ，找到一个具有最大和的连续子数组（子数组最少包含一个元素），返回其最大和。 
//
// 示例: 
//
// 输入: [-2,1,-3,4,-1,2,1,-5,4]
//输出: 6
//解释: 连续子数组 [4,-1,2,1] 的和最大，为 6。
// 
//
// 进阶: 
//
// 如果你已经实现复杂度为 O(n) 的解法，尝试使用更为精妙的分治法求解。 
// Related Topics 数组 分治算法 动态规划 
// 👍 2342 👎 0

package leetcode.editor.cn;

/**
 * 思路，遍历每个数，如果大于0，就把和相加，就把当前值当作和
 * <p>
 * 执行用时： 0 ms , 在所有 Java 提交中击败了 100.00% 的用户 内存消耗： 39.6 MB , 在所有 Java 提交中击败了 83.91% 的用户
 */
//Java：最大子序和
public class P53MaximumSubarray {

    //leetcode submit region begin(Prohibit modification and deletion)
    class Solution {
        public int maxSubArray(int[] nums) {
            int result = nums[0];
            int sum = 0;
            for (int num : nums) {
                if (sum > 0) {
                    sum += num;
                } else {
                    sum = num;
                }
                if (sum > result) {
                    result = sum;
                }
            }
            return result;
        }
    }
//leetcode submit region end(Prohibit modification and deletion)

    public static void main(String[] args) {
        int[] nums = new int[]{-2, 1, -3, 4, -1, 2, 1, -5, 4};
        Solution solution = new P53MaximumSubarray().new Solution();
        System.out.println(solution.maxSubArray(nums));
        // TO TEST
    }

}